<template>
  <div class="container">
    <van-nav-bar
      left-arrow
      @click-left="$router.back()"
      title="编辑资料"
    ></van-nav-bar>
    <!-- 用户资料 -->
    <van-cell-group>
      <van-cell is-link title="头像" @click="showPhoto = true" center>
        <van-image
          slot="default"
          width="1.5rem"
          height="1.5rem"
          fit="cover"
          round
          :src="photo"
        />
      </van-cell>
      <van-cell
        is-link
        title="名称"
        @click="showName = true"
        :value="user.name"
      />
      <van-cell
        is-link
        title="性别"
        @click="showGender = true"
        :value="user.gender === 0 ? '男' : '女'"
      />
      <van-cell
        is-link
        title="生日"
        @click="openDate()"
        :value="user.birthday"
      />
    </van-cell-group>
    <!-- 保存 -->
    <div style="margin: 20px; text-align: center">
      <van-button @click="save" type="primary">保存</van-button>
    </div>
    <!-- 弹出层=》修改用户信息 -->
    <!-- 修改登录人头像 -->
    <van-popup v-model="showPhoto" position="bottom">
      <!-- input[file]作用：
       1. 选择图片
       2. 调用相机=》拍照
       -->
      <input
        type="file"
        @change="preview"
        ref="fileInput"
        style="display: none"
      />
      <van-cell @click="$refs.fileInput.click()" value="本地相册选择" is-link />
      <van-cell @click="$refs.fileInput.click()" value="拍照" is-link />
    </van-popup>
    <!-- 修改登录人名称 -->
    <van-popup v-model="showName" position="bottom">
      <van-field v-model="user.name" required placeholder="请输入用户名" />
    </van-popup>
    <!-- 修改登录性别 -->
    <van-popup v-model="showGender" position="bottom">
      <van-cell value="男" @click="changeGender(0)" is-link />
      <van-cell value="女" @click="changeGender(1)" is-link />
    </van-popup>
    <!-- 修改登录人生日 -->
    <van-popup v-model="showBirthday" position="bottom">
      <van-datetime-picker
        title="选择生日"
        v-model="nowDate"
        type="date"
        :min-date="minDate"
        :max-date="maxDate"
        @cancel="showBirthday = false"
        @confirm="confirmDate"
      />
    </van-popup>
  </div>
</template>

<script>
// 导入dayjs
import dayjs from 'dayjs'
// 导入获取用户信息后台接口
import { getUserProfile, updateUserPhoto, updateUserInfo } from '@/api/user'
export default {
  name: 'user-profile',
  data () {
    return {
      // 弹窗控制
      showPhoto: false,
      showName: false,
      showGender: false,
      showBirthday: false,
      // 时间组件
      nowDate: new Date(), // 当前选中的用户生日
      minDate: new Date('1950-01-01'),
      // 日期控件 最大可选日期
      maxDate: new Date(),
      // 默认用户信息（假数据）
      photo: 'https://img.yzcdn.cn/vant/cat.jpeg',
      // 待修改的用户信息
      user: {
        name: '默认信息',
        gender: 0,
        birthday: '2019-10-10'
      }
    }
  },
  created () {
    this.getUser()
  },
  methods: {
    async save () {
      try {
        /**
         * 1. 上传头像(如果选择了图片)
         * 2. 修改其它信息
         */
        if (this.$refs.fileInput) {
          await updateUserPhoto(this.$refs.fileInput.files[0])
        }
        await updateUserInfo(this.user)
        this.$toast.success('修改成功')
      } catch (error) {
        console.log(error)
        this.$toast.fail('修改失败')
      }
    },
    // 获取待编辑的个人数据
    async getUser () {
      const { data } = await getUserProfile()
      console.log(data)
      this.user = data
      this.photo = data.photo
    },
    // 选择图片预览
    preview (e) {
      const file = this.$refs.fileInput.files[0]
      // console.log(file)
      // 选择完拿到的是一个File对象=》要把File对象转换成可渲染格式
      // 可渲染格式: 1.base64  2. url
      /**
       * 使用浏览器提供的FileReader方法转换
       */
      const fr = new FileReader()
      // 使用fr实例读取File对象=> 异步
      fr.readAsDataURL(file)
      fr.onload = () => {
        console.log('获取读取完的b64：', fr.result)
        // 渲染显示
        this.photo = fr.result
        // 关闭弹出层
        this.showPhoto = false
      }
    },
    openDate () {
      // 有生日数据
      if (this.user.birthday) {
        this.nowDate = new Date(this.user.birthday)
      }
      this.showBirthday = true
    },
    confirmDate (value) {
      console.log(value)
      // 确认时间后  把Date转换成String
      this.user.birthday = dayjs(value).format('YYYY-MM-DD')
      this.showBirthday = false
    },
    changeGender (gender) {
      // 选择性别 gender 0 男  1 女
      this.user.gender = gender
      this.showGender = false
    }
  }
}
</script>

<style scoped lang='less'></style>
